<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
</head>

<body>
    <script>
        /* 通过 promise 对象和 then 函数处理 */
        // 1 promise可以封装异步操作，查用户
        let p = new Promise((resolve, reject) => {
            $.ajax({
                url: "mock/user.json",
                success: function (data) {
                    console.log("查询用户成功", data);
                    resolve(data);
                },
                error: function (err) {
                    reject(err);
                }
            })
        });
        // 2 这里的obj就是上一步给我们传下来的data，在此接收，查课程
        let p1 = p.then(obj => {
            return new Promise((resolve, reject) => {
                $.ajax({
                    url: `mock/user_corse_${obj.id}.json`,
                    success: function (data) {
                        console.log("查询用户课程成功", data);
                        resolve(data);
                    },
                    error: function (err) {
                        reject(err);
                    }
                });
            })
        }).catch((err) => {

        })
        // 3 查分数
        p1.then((data) => {
            $.ajax({
                url: `mock/corse_score_${data.id}.json`,
                success: function (data) {
                    console.log("查询分数成功", data);
                },
                error: function (err) {
                }
            });
        })
    </script>
</body>

</html>